package com.quick.generator.domain;

import com.quick.common.core.domain.BaseEntity;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.apache.commons.lang3.StringUtils;

import javax.validation.constraints.NotBlank;

/**
 * 代码生成业务字段表 gen_table_column
 *
 * @Author: quick
 */
@EqualsAndHashCode(callSuper = true)
@Data
public class GenTableColumn extends BaseEntity {
    private static final long serialVersionUID = 1L;

    /**
     * 编号
     */
    private Long columnId;

    /**
     * 归属表编号
     */
    private Long tableId;

    /**
     * 列名称
     */
    private String columnName;

    /**
     * 列描述
     */
    private String columnComment;

    /**
     * 列类型
     */
    private String columnType;

    /**
     * JAVA类型
     */
    private String javaType;

    /**
     * JAVA字段名
     */
    @NotBlank(message = "Java属性不能为空" )
    private String javaField;

    /**
     * 是否主键（1是）
     */
    private String isPk;

    /**
     * 是否自增（1是）
     */
    private String isIncrement;

    /**
     * 是否必填（1是）
     */
    private String isRequired;

    /**
     * 是否为插入字段（1是）
     */
    private String isInsert;

    /**
     * 是否编辑字段（1是）
     */
    private String isEdit;

    /**
     * 是否列表字段（1是）
     */
    private String isList;

    /**
     * 是否查询字段（1是）
     */
    private String isQuery;

    /**
     * 查询方式（EQ等于、NE不等于、GT大于、LT小于、LIKE模糊、BETWEEN范围）
     */
    private String queryType;

    /**
     * 显示类型（input文本框、textarea文本域、select下拉框、checkbox复选框、radio单选框、datetime日期控件、image图片上传控件、upload文件上传控件、editor富文本控件）
     */
    private String htmlType;

    /**
     * 字典类型
     */
    private String dictType;

    /**
     * 排序
     */
    private Integer sort;

    public static boolean isUsableColumn(String javaField) {
        return StringUtils.equalsAnyIgnoreCase(javaField, "parentId" , "orderNum" , "remark" );
    }

    public boolean isPk() {
        return isPk != null && StringUtils.equals("1" , isPk);
    }

    public boolean isIncrement(String isIncrement) {
        return isIncrement != null && StringUtils.equals("1" , isIncrement);
    }

    public boolean isRequired() {
        return isRequired != null && StringUtils.equals("1" , isRequired);
    }

    public boolean isInsert() {
        return isInsert != null && StringUtils.equals("1" , isInsert);
    }

    public boolean isEdit() {
        return isEdit != null && StringUtils.equals("1" , isEdit);
    }

    public boolean isList() {
        return isList != null && StringUtils.equals("1" , isList);
    }

    public boolean isQuery() {
        return isQuery != null && StringUtils.equals("1" , isQuery);
    }

    public boolean isSuperColumn() {
        return !StringUtils.equalsAnyIgnoreCase(javaField,
                // BaseEntity
                "createBy" , "createTime" , "updateBy" , "updateTime" , "remark" ,
                // TreeEntity
                "parentName" , "parentId" , "orderNum" , "ancestors" );
    }

    public boolean isUsableColumn() {
        return isUsableColumn(javaField);
    }
    public String getCapJavaField() {
        return StringUtils.capitalize(javaField);
    }

    public String readConverterExp() {
        String remarks = StringUtils.substringBetween(this.columnComment, "（" , "）" );
        StringBuilder sb = new StringBuilder();
        if (StringUtils.isNotEmpty(remarks)) {
            for (String value : remarks.split(" " )) {
                if (StringUtils.isNotEmpty(value)) {
                    Object startStr = value.subSequence(0, 1);
                    String endStr = value.substring(1);
                    sb.append(startStr).append("=" ).append(endStr).append("," );
                }
            }
            return sb.deleteCharAt(sb.length() - 1).toString();
        } else {
            return this.columnComment;
        }
    }
}
